package 程序员面试金典;

import java.util.ArrayList;
import java.util.List;

/**
 * 面试题 08.04. 幂集
 * 幂集。编写一种方法，返回某集合的所有子集。集合中不包含重复的元素。
 *
 * 说明：解集不能包含重复的子集。
 *
 * 示例:
 *
 *  输入： nums = [1,2,3]
 *  输出：
 * [
 *   [3],
 *   [1],
 *   [2],
 *   [1,2,3],
 *   [1,3],
 *   [2,3],
 *   [1,2],
 *   []
 * ]
 */
public class T08_04 {
    public List<List<Integer>> subsets(int[] nums) {

        List<List<Integer>> ans = new ArrayList<>();

        ans.add(new ArrayList<>());

        //遍历数组 每拿到一个数字 就把结果集 复制一份将新数字加入到每个集合后面 共同构成新的结果集

        for (int i = 0; i < nums.length; i++) {
            int number = nums[i];
            //遍历结果集
            int size = ans.size();
            for (int j = 0; j < size; j++) {
                ArrayList<Integer> temp = new ArrayList<>(ans.get(j));
                temp.add(number);
                ans.add(temp);
            }
        }
        return ans;
    }
}
